草庐IT

database - 从 Swift 连接到 Postgres

全部标签

sockets - Golang - 为到不同服务器的多个连接扩展 websocket 客户端

我有一个websocket客户端。实际上,它比下面显示的基本代码复杂得多。我现在需要扩展此客户端代码以打开到多个服务器的连接。最终,从服务器接收到消息时需要执行的任务是相同的。处理这个问题的最佳方法是什么?正如我上面所说,接收消息时执行的实际代码比示例中显示的要复杂得多。packagemainimport("flag""log""net/url""os""os/signal""time""github.com/gorilla/websocket")varaddr=flag.String("addr","localhost:1234","httpserviceaddress")funcm

go - 如何与本地主机上的 mysql 服务器建立连接?

我想与本地主机上的sqlserver建立新连接,以便能够从sqlserver获取数据。但是在连接时出现了一些问题。错误:-[mysql]2019/02/1115:30:00driver.go:81:net.ErrorfromDial()':dialtcpserverPort:3306:connect:connectiontimedout我使用的代码是funcConnectMsqlDb()(db*sql.DB,errerror){db,err=sql.Open("mysql",fmt.Sprintf("%s:%s@tcp(%s:"+SqlDbPort+")/"+SqlDatabase,S

go - 通过 SSH golang 连接到 mongoDB

我需要通过ssh连接到远程mongoDB服务器,我之前是用mysql做的,它看起来像:sshcon,err:=ssh.Dial("tcp",fmt.Sprintf("%s:%d",sshHost,sshPort),sshConfig)iferr==nil{defersshcon.Close()mysql.RegisterDial("mysql+tcp",(&ViaSSHDialer{sshcon}).Dial)mgo包里有类似mysql.RegisterDial的函数吗? 最佳答案 将隧道功能添加到您的代码中确实没有意义。一个简单的

azure - golang COSMOS DB,快速入门,缺少环境变量 AZURE_DATABASE

更新:初始化函数中使用的GetEnvVarOrExit已弃用。(但可能仍然有效)2。(这有效)快速的解决方案是以这种方式简单地编辑init()函数......funcinit(){//database=utils.GetEnvVarOrExit("AZURE_DATABASE")//password=utils.GetEnvVarOrExit("AZURE_DATABASE_PASSWORD")database="testDBForStart"password="lTy8axgO6O49JaR2GetYourOwnPasswordFromPortala7yNucQ=="}第三个选项是设

ssl - RabbitMQ - Tls 连接 - Golang

我使用以下链接配置了RabbitMQ连接:https://github.com/streadway/amqp/blob/master/examples_test.go我根据此处的说明创建的证书:https://www.rabbitmq.com/ssl.html#enabling-tls-paths我使用安装在docker中的RabbitMQ3.7.0。调用amqp.DialTLS后,我在服务器端(在docker日志中)收到“证书错误”错误。我想问题是证书应该包含服务器名称,如果是这样,如果RabbitMQ安装在docker中,我应该在证书中设置哪个服务器名称?除此之外,还有什么想法吗?

postgresql - 使用 xo 从 postgres 数据库表模式生成 DTO 结构

我只是想知道是否有人使用过xo.我有一个Postgres数据库,里面有一堆表和东西。我似乎无法使用xo从postgres表结构生成DTOstruct。这个内置的xotemplate似乎创建了一个struct,我相信xo默认使用内置模板,但我在运行时得到的都是xo--verbose--suffix'.go'pgsql://myusername:mypass@localhost:myport/mydb?sslmode=disable-ointernal/qo/models-pqo是一堆与我的项目或我的数据库中的模式完全无关的文件。 最佳答案

reactjs - 如何使用 Golang Gorilla/mux 托管并发 websocket 连接?

在此先感谢您的任何帮助或建议!我正在构建一个国际象棋应用程序,前端使用Reactjs,后端是使用Golillamux库用Golang编写的服务器。后端是一个供人类用户下棋的国际象棋引擎。React前端在顶级构造函数中创建与服务器的WebSocket连接。该应用程序适用于单个连接。但是,在打开第二个浏览器选项卡时,第一个浏览器选项卡的Websocket连接丢失。服务器报错,readerror:websocket:close1001(goingaway)然后,readerror:readtcp127.0.0.1:8081-\u003e127.0.0.1:64146:useofclosedn

database - 未找到实体时的正确错误处理

我正在编写一个包含数据库包的Go应用程序。现在在数据库包中有几个方法,您可以调用它们来获取基于某些字段的实体。我想知道当没有找到实体时,Go中错误处理的最佳实践是什么。我应该在自己的数据库包中返回错误还是返回nil作为值?我知道当没有找到实体时,谷歌的数据存储会返回错误。现在我正在使用gorm,当没有找到实体时它也会返回错误。我想知道您是否可以简单地返回nil作为值而不是返回错误。我漏掉了一点吗? 最佳答案 如果您使用的是gorm,则有一个专门用于该功能的函数;即,//IsRecordNotFoundErrorreturnstrue

go - 为什么这个 go 例程在关闭阻塞读取连接时随机无法退出?

为什么这个接收者在连接关闭时进入例程拒绝终止这按预期运行,但随后随机地,每调用20-10,000次,接收器将无法关闭,然后导致goroutine泄漏,导致100%cpu。注意:如果我记录所有错误,如果conn.SetReadDeadline被注释掉,我将在关闭的channel上看到读取。使用时,我将i/o超时视为错误。这运行了10k个周期,其中主进程启动了11对这样的发送/接收方,它们在主进程发送关闭信号之前处理了1000个作业。此设置在一夜之间运行了6小时以上而没有任何问题,达到10k个周期标记,但今天早上我无法让它运行超过20个周期而没有将接收器标记为未关闭和退出。funcsend

docker - 无法连接到 docker 容器中的数据库主机,从 api-service 到 db-service,以便在 golang 中使用 goose 进行迁移

goose是帮助我运行所有*sql文件并在数据库中运行查询的迁移工具。我想在我的api服务的docker容器中使用此工具自动执行迁移(创建表和其他内容)。问题是当docker运行命令“gooserun”时出现错误-gooserun:dialtcp:lookupdbon192.168.63.6:53:nosuchhost。docker-composeservices:db:build:./dbvolumes:-./db/pgdata:/pgdataimage:postgresports:-"5432"restart:alwaysenvironment:-POSTGRES_USER=use